# CS330 Architecture and Organization Assignment Appendix B

Jingbo Wang

**Problem B.2** — (5 points) In addition to the basic laws we discussed in this section, there are two important theorems, called DeMorgan's theorems:

$$\overline{A+B} = \overline{A} \cdot \overline{B}$$
 and  $\overline{A \cdot B} = \overline{A} + \overline{B}$ 

Prove that the two equations for E in the example starting on page B-7 are equivalent by using DeMorgan's theorems and the axioms shown on page B-7. (Section B.2)

#### Answer:

$$E = ((A \cdot B) + (A \cdot C) + (B \cdot C)) \cdot (\overline{A \cdot B \cdot C})$$

$$= ((A \cdot B) + (A \cdot C) + (B \cdot C)) \cdot ((\overline{A \cdot B}) + \overline{C})$$

$$= ((A \cdot B) + (A \cdot C) + (B \cdot C)) \cdot (\overline{A} + \overline{B} + \overline{C})$$

$$= A \cdot B \cdot \overline{A} + A \cdot B \cdot \overline{B} + A \cdot B \cdot \overline{C} + A \cdot C \cdot \overline{A}$$

$$+ A \cdot C \cdot \overline{B} + A \cdot C \cdot \overline{C} + B \cdot C \cdot \overline{A} + B \cdot C \cdot \overline{B} + B \cdot C \cdot \overline{C}$$

$$= (A \cdot B \cdot \overline{C}) + (A \cdot \overline{B} \cdot C) + (\overline{A} \cdot B \cdot C)$$

**Problem B.4** — (6 points) One logic function that is used for a variety of purposes (including within adders and to compute parity) is *exclusive OR*. The output of a two-input exclusive OR function is true only if exactly one of the inputs is true. Show the truth table for an exclusive OR function and implement this function using AND gates, OR gates, and inverters. (Section B.4)

A XOR 
$$B = A\overline{B} + \overline{A}B$$

| AB  | A XOR B |
|-----|---------|
| 0.0 | 0       |
| 0 1 | 1       |
| 1 0 | 1       |
| 1 1 | 0       |

Table 1: exclusive OR function



0 **Problem B.6** — (5 points) Prove that the NAND gate is universal by showing how to build the AND, OR, and NOT functions using two-input NAND gates. (Section B.2)

#### Answer:

AND function:  $A \cdot B = \overline{\overline{A \cdot B}} = \overline{A \ NAND \ B}$ 



OR function:  $A + B = \overline{\overline{A + B}} = \overline{\overline{A} \cdot \overline{B}} = \overline{A}$  NAND  $\overline{B}$ 



NOT function:  $\overline{A} = \overline{A \cdot A} = A$  NAND A



**Problem B.10** — (5 points) Prove that a two-input multiplexor is also universal by showing how to build the NAND (or NOR) gate using two-input multiplexors. (Sections B.2 and B.3)

### Answer:

NAND function:



**Problem B.14** — (6 points) Implement a switching network that has two data inputs (A and B), two data outputs (C and D), an a control input (S). If S equals 1, the network is in pass-through mode and C should equal A and D should equal B. If S equals 0, the network is in crossing mode and C should equal B, and D should equal A. (Sections B.2 and B.3)



**Problem B.24** — (6 points) The ALU supported set on less than ( $\mathfrak{slt}$ ) using just the sign bit of the adder. Let's try a set on less than operation using the values  $-7_{\rm ten}$  and  $6_{\rm ten}$ . To make it simpler to follow the example, let's limit the binary representations to 4 bits  $1001_{\rm two}$  and  $0110_{\rm two}$ .

$$1001_{\text{two}} - 0110_{\text{two}} = 1001_{\text{two}} + 1010_{\text{two}} = 0011_{\text{two}}$$

This result would suggest that -7 > 6, which is clearly wrong. Hence, we must factor in overflow in the decision. Modify the 1-bit ALU in Figure B.5.10 on page B-33 to handle slt correctly. Make your changes on a photocopy of this figure to save time. (Section B.5)



**Problem B.36** — (10 points) Figure B.8.8 on page B-55 illustrates the implementation of the register file for the MIPS datapath. Pretend that a new register file is to be built, but that there are only two registers and only one read port, and that each register has only 2 bits of data. Redraw Figure B.8.8 so that every wire in your diagram corresponds to only 1 bit of data (unlike the diagram in figure B.8.8, in which some wires are 5 bits and some wires are 32 bits). Redraw the registers using D flip-flops. You do not need to show how to implement a D flip-flop or a multiplexor. (Section B.8)

